package com.sky.mapper;

import com.sky.entity.Faq;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;
import org.apache.ibatis.annotations.Select;

import java.util.List;

/**
 * FAQ Mapper接口
 */
@Mapper
public interface FaqMapper {

    /**
     * 通过问题关键词搜索FAQ
     * @param keyword 关键词
     * @return FAQ列表
     */
    @Select("SELECT * FROM faq WHERE status = 1 AND question LIKE CONCAT('%', #{keyword}, '%') ORDER BY id DESC LIMIT 5")
    List<Faq> searchByKeyword(@Param("keyword") String keyword);
    
    /**
     * 插入FAQ
     * @param faq FAQ对象
     */
    void insert(Faq faq);
    
    /**
     * 更新FAQ
     * @param faq FAQ对象
     */
    void update(Faq faq);
    
    /**
     * 根据ID删除FAQ
     * @param id FAQ ID
     */
    void deleteById(Long id);
    
    /**
     * 根据ID查询FAQ
     * @param id FAQ ID
     * @return FAQ对象
     */
    @Select("SELECT * FROM faq WHERE id = #{id}")
    Faq getById(@Param("id") Long id);
    
    /**
     * 根据分类查询FAQ列表
     * @param category 分类
     * @return FAQ列表
     */
    @Select("SELECT * FROM faq WHERE status = 1 AND category = #{category} ORDER BY id DESC")
    List<Faq> listByCategory(@Param("category") String category);
    
    /**
     * 查询所有FAQ
     * @return FAQ列表
     */
    @Select("SELECT * FROM faq ORDER BY id DESC")
    List<Faq> listAll();
} 